| Arithmetic/logical (instruction formats)                                               | R-R, R-I       | R-R, R-I                     | R-R, R-I            | R-R, R-I                     | R-R, R-I         |
|----------------------------------------------------------------------------------------|----------------|------------------------------|---------------------|------------------------------|------------------|
| Instruction name                                                                       | ARM v8         | MIPS64                       | Power v3            | RISC-V                       | SPRC v.9         |
| Add word, immediate                                                                    | ADD, ADDI      | ADDU,<br>ADDUI,              | ADD, ADDI           | ADDW,<br>ADDWI               | ADD              |
| Add double word                                                                        | ADDX           | DADDU,<br>DADDUI             | ADD, ADDI           | ADD, ADDI                    | ADD              |
| Subtract                                                                               | SUB,SUBI       | SUBU,SUBI                    | SUBF                | SUBW,<br>SUBWI               | SUB              |
| Subtract double word                                                                   | SUBX           | DSUBU, DSUBUI                | SUBF                | SUB, SUBI                    | SUB              |
| Multiply                                                                               | MUL,SMUL       | MUL, MULU,<br>DMUL, DMULU    | MULLW,<br>MULLIMUL, | MULU,<br>MULW,<br>MULWU      | MULX             |
| Divide                                                                                 | MULX,<br>SMULX | DIV,<br>DIVU, DDIV,<br>DDIVU | DIVW                | DIV, DIVU,<br>DIVW,<br>DIVWU | DIVX             |
| Remainder                                                                              |                | MOD, MODU,<br>DMOD, DMODU    | MODSW, MODUW        | REM, REMU,<br>REMW,<br>REMWU |                  |
| And                                                                                    | AND, ANDI      | AND, ANDI                    | AND, ANDI           | AND, ANDI                    | AND              |
| Or                                                                                     | OR,ORI         | OR,ORI                       | OR,ORI              | OR,ORI                       | OR               |
| Xor                                                                                    | XOR,XORI       | XOR,XORI                     | XOR,XORI            | XOR,XORI                     | XOR              |
| Load bits 3116                                                                         | MOV            | LUI                          | ADDIS               | ADDIS                        | SETHI<br>(Bfmt.) |
| Load upper bits of PC                                                                  | ADR            | ADDIUPC                      | ADDPCIS             | AUIPC                        |                  |
| Shift left logical, double word and word versions, immediate and variable              | LSL            | SLLV, SLL                    | RLWINM              | SLL, SLLI,<br>SLLW, SLLWI    | SLL              |
| Shift left logical, double word and word versions, immediate and variables             | RSL            | SRLV, SRL                    | RLWINM<br>32-i      | SRL, SRLI,<br>SRLW, SRLWI    | SRL              |
| Shift right arithmetic,<br>double word and word<br>versions, immediate and<br>variable | RSA            | SRAV, SRA                    | SRAW                | SRA, SRAI,<br>SRAW, SRAWI    | SRA              |
| Compare                                                                                | CMP            | SLT/U, SL<br>TI/U            | CMP(I) CLR          | SLT/U,<br>SLTI/U             | SUBcc r0,        |

FIGURE E.10 Desktop RISC arithmetic/logical instructions equivalent to RISC-V integer ISA. MIPS also provides instructions that trap on arithmetic overflow, which are synthesized in other architectures with multiple instructions. Note that in the "Arithmetic/logical" category all machines but SPARC use separate instruction mnemonics to indicate an immediate operand; SPARC offers immediate versions of these instructions but uses a single mnemonic. (Of course, these are separate opcodes!).